package com.ian.offer;

/**
 * @author zhangyaowen
 * @date 2021/3/9 10:05 下午
 */

/**
 * 一只青蛙一次可以跳上1级台阶，也可以跳上2级台阶。求该青蛙跳上一个 n 级的台阶总共有多少种跳法。
 *
 * 答案需要取模 1e9+7（1000000007），如计算初始结果为：1000000008，请返回 1。
 *
 * 示例 1：
 *
 * 输入：n = 2
 * 输出：2
 * 示例 2：
 *
 * 输入：n = 7
 * 输出：21
 * 示例 3：
 *
 * 输入：n = 0
 * 输出：1
 * 提示：
 *
 * 0 <= n <= 100
 *
 * 来源：力扣（LeetCode）
 * 链接：https://leetcode-cn.com/problems/qing-wa-tiao-tai-jie-wen-ti-lcof
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 */
public class NumWays {

    public int numWays(int n) {

        int a =0,b =1,sum;

        for (int i = 0; i < n; i++) {
            //i 代表层数
            //A 代表第I层的走法
            //B 代表I+1层的走法
            // I+1 层  = I-1 +I 层
            sum = (a+b)%1000000007;
            a = b;
            b = sum;
        }

        return  a;

    }

    public static void main(String[] args) {

        NumWays numWays = new NumWays();
       int r =  numWays.numWays(5);
        System.out.println(r);
    }
}
